package temp.leetcode.editor.cn;

//给你一个含重复值的二叉搜索树（BST）的根节点 root ，找出并返回 BST 中的所有 众数（即，出现频率最高的元素）。
//
// 如果树中有不止一个众数，可以按 任意顺序 返回。
//
// 假定 BST 满足如下定义：
//
//
// 结点左子树中所含节点的值 小于等于 当前节点的值
// 结点右子树中所含节点的值 大于等于 当前节点的值
// 左子树和右子树都是二叉搜索树
//
//
//
//
// 示例 1：
//
//
//输入：root = [1,null,2,2]
//输出：[2]
//
//
// 示例 2：
//
//
//输入：root = [0]
//输出：[0]
//
//
//
//
// 提示：
//
//
// 树中节点的数目在范围 [1, 10⁴] 内
// -10⁵ <= Node.val <= 10⁵
//
//
//
//
// 进阶：你可以不使用额外的空间吗？（假设由递归产生的隐式调用栈的开销不被计算在内）
//
// Related Topics 树 深度优先搜索 二叉搜索树 二叉树 👍 618 👎 0

import temp.二叉树.TreeNode;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

/**
 * 二叉搜索树中的众数
 *
 * @author saint
 */
class P501_FindModeInBinarySearchTree{
    public static void main(String[] args) {
        Solution solution = new P501_FindModeInBinarySearchTree().new Solution();

    }

    //leetcode submit region begin(Prohibit modification and deletion)
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    List<Integer> res = new ArrayList<>();
    TreeNode pre = null;
    int maxCount =-1;
    int count = 0;
    public int[] findMode(TreeNode root) {
        getMode(root);
        return res.stream().mapToInt(Integer::intValue).toArray();
    }

    public void getMode(TreeNode root){
        if (root == null){
            return;
        }
        getMode(root.left);
        if (pre == null){
            count = 1;
        }
        else if (pre.val == root.val){
            count++;
        }
        else if(pre.val!=root.val){
            count =1;
        }
        pre = root;
        //更新结果
        if (count>maxCount){
            res.clear();
            res.add(root.val);
            maxCount = count;
        }else if (count == maxCount){
            res.add(root.val);
        }
        getMode(root.right);
    }
}
//leetcode submit region end(Prohibit modification and deletion)

}
